﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using DTTB.Common;
using DTTB.MV2.QUANLYNHANSUTIENLUONG.Models.FormBean.NhanVienModel;
using DTTB.MV2.QUANLYNHANSUTIENLUONG.Models.LinQ.NhanVien;
using Webdiyer.WebControls.Mvc;

namespace DTTB.MV2.QUANLYNHANSUTIENLUONG.BussinessDelegate.NhanVienDelegate
{
    public class XeVT_NgayBHDelegate
    {
        private NhanVienDataContext db = new NhanVienDataContext();
        int _UserId = Convert.ToInt32(HttpContext.Current.Session["USERID"]);
        int _DeparmentId = Convert.ToInt32(HttpContext.Current.Session["DEPARTMENT"]);
        DateTime _DateNow = DateTime.Now;
        public IList<pt_XeVanTai_NgayBaoHiemXe> GetAllXeVT_NgayBH()
        {
            return db.pt_XeVanTai_NgayBaoHiemXes.Where(p => p.IsDelete == false).ToList();
        }
        
        public pt_XeVanTai_NgayBaoHiemXe Insert(pt_XeVanTai_NgayBaoHiemXe obj)
        {
            try
            {

                obj.CreateBy = _UserId;
                obj.CreateDate = _DateNow;
                db.pt_XeVanTai_NgayBaoHiemXes.InsertOnSubmit(obj);
                db.SubmitChanges();
                return obj;
            }
            catch (Exception)
            {
                return null;
            }
        }
        public pt_XeVanTai_NgayBaoHiemXe AddNewXeVT_NgayBH(pt_XeVanTai_NgayBaoHiemXe Luong)
        {
            db.pt_XeVanTai_NgayBaoHiemXes.InsertOnSubmit(Luong);
            db.SubmitChanges();
            return Luong;
        }

        public bool DeleteXeVT_NgayBH(int ID)
        {
            try
            {
                pt_XeVanTai_NgayBaoHiemXe LuongNew =
               db.pt_XeVanTai_NgayBaoHiemXes.Single(p => p.Id == ID);

                db.pt_XeVanTai_NgayBaoHiemXes.DeleteOnSubmit(LuongNew);
                db.SubmitChanges();
                return true;
            }
            catch (Exception)
            {
                return false;
            }
        }
        public bool UpdateXeVT_NgayBH(pt_XeVanTai_NgayBaoHiemXe XeVT_NgayBH)
        {
            try
            {
                pt_XeVanTai_NgayBaoHiemXe XeVT_NgayBHUpdate =
                    db.pt_XeVanTai_NgayBaoHiemXes.Single(p => p.Id == XeVT_NgayBH.Id);
                if (XeVT_NgayBHUpdate != null && XeVT_NgayBHUpdate.IsDelete == false)
                {
                    XeVT_NgayBHUpdate.Id = XeVT_NgayBH.Id;
                    XeVT_NgayBHUpdate.IdXeVanTai = XeVT_NgayBH.IdXeVanTai;
                    XeVT_NgayBHUpdate.UpdateDate = XeVT_NgayBH.UpdateDate;
                    XeVT_NgayBHUpdate.UpdateBy = XeVT_NgayBH.UpdateBy;
                    db.SubmitChanges();
                    return true;
                }
                else
                {
                    return false;
                }
            }
            catch(Exception)
            {
                return false;
            }
        }
        public pt_XeVanTai_NgayBaoHiemXe GetXeVT_NgayBHById(string id)
        {
            try
            {
                pt_XeVanTai_NgayBaoHiemXe item = this.db.pt_XeVanTai_NgayBaoHiemXes.Single(p => p.Id == Convert.ToInt32(id));
                return item;
            }
            catch (Exception)
            {
                return null;
            }
        }
        public pt_XeVanTai_NgayBaoHiemXe BuildnewXeVT_NgayBH(XeVT_NgayBHForm form)
        {
            pt_XeVanTai_NgayBaoHiemXe newXeVT_NgayBH = new pt_XeVanTai_NgayBaoHiemXe();
            newXeVT_NgayBH.IdXeVanTai = form.IdXeVanTai;
            newXeVT_NgayBH.NgayBaoHiem = form.NgayBaoHiem;
     
            newXeVT_NgayBH.CreateBy = Convert.ToInt32(HttpContext.Current.Session["USERID"]);
            newXeVT_NgayBH.CreateDate = DateTime.Now;
            newXeVT_NgayBH.IsDelete = false;
            return newXeVT_NgayBH;
        }


        public pt_XeVanTai_NgayBaoHiemXe BuildEditXeVT_NgayBH(XeVT_NgayBHForm form)
        {
            pt_XeVanTai_NgayBaoHiemXe newXeVT_NgayBH = new pt_XeVanTai_NgayBaoHiemXe();
            newXeVT_NgayBH.Id = form.Id;
            newXeVT_NgayBH.IdXeVanTai = form.IdXeVanTai;
            newXeVT_NgayBH.NgayBaoHiem = form.NgayBaoHiem;

            newXeVT_NgayBH.UpdateDate = DateTime.Now;
            newXeVT_NgayBH.UpdateBy = Convert.ToInt32(HttpContext.Current.Session["USERID"]);
            return newXeVT_NgayBH;
        }

        public pt_XeVanTai_NgayBaoHiemXe GetLoaiCongChucIdMax()
        {
            IList<pt_XeVanTai_NgayBaoHiemXe> list = db.pt_XeVanTai_NgayBaoHiemXes.ToList();
            return list.Count != 0 ? list.ElementAt(list.Count - 1) : null;
        }

        public XeVT_NgayBHForm ConvertToForm(pt_XeVanTai_NgayBaoHiemXe obj)
        {
            XeVT_NgayBHForm form = new XeVT_NgayBHForm();
            form.Id = obj.Id;
            form.IdXeVanTai = obj.IdXeVanTai;
            form.NgayBaoHiem = obj.NgayBaoHiem;
            form.UpdateDate = obj.UpdateDate != null ? obj.UpdateDate.Value : DateTime.MinValue;
            form.CreateDate = obj.CreateDate != null ? obj.CreateDate.Value : DateTime.MinValue;
            form.UpdateBy = obj.UpdateBy != null ? obj.UpdateBy.Value : 0;
            form.CreateBy = obj.CreateBy != null ? obj.CreateBy.Value : 0;
            return form;
        }
        public IQueryable<pt_XeVanTai_NgayBaoHiemXe> GetAll(int IdXeVanTai)
        {
            return db.pt_XeVanTai_NgayBaoHiemXes.Where(p => p.IsDelete == false && p.IdXeVanTai == IdXeVanTai).OrderByDescending(p => p.CreateBy);
        }
        public SelectList BuildXeVT_NgayBH(int IdXeVT_NgayBH)
        {
            SelectList list = new SelectList(db.dm_TienComs.Where(p => p.IsDelete == false).ToList(), "Id", "TienCom", IdXeVT_NgayBH);
            return list;
        }
        public pt_XeVanTai_NgayBaoHiemXe ConvertToLinq(XeVT_NgayBHForm form)
        {
            pt_XeVanTai_NgayBaoHiemXe obj = new pt_XeVanTai_NgayBaoHiemXe();
            obj.IdXeVanTai = form.IdXeVanTai;
            obj.Id = form.Id;
            obj.NgayBaoHiem =form.NgayBaoHiem;
            return obj;
        }
    }
}